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Method and System for Object Cache Synchronization 

5 

This invention relates to the field of databases and, more specifically, to a 
system and method for managing object caches that maintain objects read 
from databases. 

10 BACKGROUND OF THE INVENTION 

Object model technology is becoming more popular for building 
enterprise applications and it is desirable to allow object applications to obtain 
and manipulate objects in databases where corporate and other data is 
typically stored. Accordingly, there is a need to efficiently acquire and store 

15 objects from a database, and an object caching mechanism is one solution to 
accomplish this. In this technique, an in-memory object cache may maintain 
the object read from the database. Then, if the same object is requested, the 
object is read from the in-memory cache instead of the database. In this 
manner, objects are acquired more efficiently. 

20 However, if several database clients or several application servers 

have an in-memory object cache, the in-memory object caches may fall out of 
synchronization with each other and with the database. This can lead to the 
increased probability of stale data and potential data corruption. 

Refreshing the in-memory cache on a query-by-query basis is one 

25 solution to this problem. However, in this approach, every query against the 
cache must access the database and refresh the cached instances with the 
database data. By accessing the database in this manner, the efficiency of 
caching is reduced. 

It is therefore desirable to provide a method and system that allow a 

30 synchronization of objects caches. 

SUMMARY OF THE INVENTION 

It is an object of the present invention to overcome one or more of the 
problems cited above. 
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It is an object of the invention to provide a system and method for 
providing information respecting a change in an object to another system that 
maintains the object in the object cache. 

The present invention distributes the change information through the 
5 network. To distribute the change information, it uses the communication link 
with another system. 

In accordance with an aspect of the present invention, there is provided 
a method for providing object change information from a first system to a 
second system which has an object cache for storing objects for 
10 synchronizing the second system with the first system. The method comprises 
the steps of changing an object in the first system, determining object change 
information representing change made to the object in the first system, and 
distributing the object change information from the first system to the second 
system to cause the second system to merge the object change information 
15 into the object cache so as to synchronize the second system with the first 
system. 

In accordance with another aspect of the present invention, there is 
provided a method for providing object change information from a first system 
to a second system for synchronizing the second system with the first system. 

20 The first system has a first object cache for storing one ore more objects. The 
second system has a second object cache for storing one ore more objects. 
The method comprises the steps of determining object change information 
representing a change made to an object in the first system, and distributing 
the object change information from the first system to the second system to 

25 cause the second system to merge the object change information into the 
second object cache so as to synchronize the object in the second object 
cache with the changed object in the first system. 

In accordance with another aspect of the present invention, there is 
provided a synchronization executor for providing object change information 

30 from a first system to a second system for synchronizing the second system 
with the first system. The first system is capable of changing the object. The 
second system has an object cache for storing objects. The executor 
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comprises a synchronization manager for obtaining object change information 
representing change made to an object in the first system, and a dispatcher 
for distributing the object change information from the first system to the 
second system to cause the second system to merge the object change 

5 information into the object cache so as to synchronize the object in the 
second system in the first system. 

In accordance with another aspect of the present invention, there is 
provided a persistence system for synchronizing an object on a network that 
includes a caching a system having an object cache for storing objects. The 

10 system comprises a transaction manager for changing an object and 

determining object change information representing the change made to the 
object for updating a database , and a synchronization executor for obtaining 
the object change information from the transaction manager and distributing 
the object change information to the caching system to cause the caching 

15 system to merge the object change information into the object cache so as to 
synchronize the object in the object cache with the changed object in the 
persistence system. 

Other aspects and features of the present invention will be readily 
apparent to those skilled in the art from a review of the following detailed 

20 description of the preferred embodiments in conjunction with the 
accompanying drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The invention will be further understood from the following description 
25 with reference to the drawings in which: 

Figure 1 is a block diagram showing a network to which a 
synchronization executor in accordance with one embodiment of the present 
invention is applied. 

Figure 2 is a block diagram showing an example of the object 
30 persistence system 100. 

Figure 3 is a flowchart showing a modification operation of the object 
persistence system. 
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Figure 4 is a block diagram showing a communication link for 
synchronization. 

Figure 5 is a block diagram showing an example of a persistence 
executor 205a. 

5 Figures 6-8 are pictorial diagrams illustrating a scenario showing the 

communication link. 

Figure 9 is a block diagram showing an example of an application 
server to which the object persistence system 100 is applied. 

Figure 10 is a block diagram showing an example of a database client 
10 to which the object persistence system 100 is applied. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Fig.1 shows an example of a network to which a synchronization 
executor 104a in accordance with one embodiment of the present invention is 

15 applied. A network shown Fig.1 includes object persistence systems 100, 101 
and 102. However, the network may include greater or fewer object 
persistence systems. Each object persistence system 100-102 manages one 
or more databases. In Fig.1, one database sever 111 including one database 
110 is shown. The object persistence systems 100-102 include in-memory 

20 object caches 103a, 103b, 103c, respectively. Each in-memory object cache 
103a, 103b, 103c stores objects read from the database 110. Each in-memory 
object cache 103b, 103c may be similar to the in-memory object cache103a. 

For example, once the object persistence system 100 reads an object 
from the database 1 10, it may be saved in the in-memory object cache 103a. 

25 If the object is requested again in the object persistence system 100, the 
object persistence system 100 will read the object in the in-memory object 
cache 103a . This eliminates the need for a database call. 

The object persistence system 100 further includes the synchronization 
executor 104a.The synchronization executor 104a distributes information of 

30 changes of the objects in the object persistence system 1 00 to one or more 
object persistence systems through a communication link as described below. 
The synchronization executor 104a receives information of changes of the 
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objects from the other object persistence systems, such as the object 
persistence system 101. 

The object persistence system101 further includes a synchronization 
executor 104b. The synchronization executor 104b may be similar to the 
5 synchronization executor 104a. 

The object persistence system 1 02 further includes a unit (now shown) 
for receiving distributed information of changes of the objects and does not 
include the synchronization executor 104a. 

The object persistence systems 100-102 receive and merge the 
10 distributed information of changes of the objects into the in-memory object 
cache 103a-103c, respectively. 

When an object persistence system distributes the information of 
changes of the objects, the object persistence system that distributes the 
information of changes of the objects is referred to as a local object 
15 persistence system. 

When an object persistence system receives the information of 
changes of the objects, the object persistence system that receives the 
information of changes of the objects is referred to as a remote object 
persistence system, however, it is not necessary for the remote object 
20 persistence system to be remotely located from the local object persistence 
system. 

The local object persistence system and the remote object persistence 
system are connected through a communication mechanism or system. The 
local and remote object persistence systems synchronize their in-memory 

25 object caches with each other through the communication link established by 
the communication mechanism or system. The communication mechanism or 
system is further described in more detail below. 

In Fig.1, the object persistence system 102 is shown separately from 
each object persistence system 100 or 101. However, it is not necessary for 

30 the object persistence system 102 to be remotely located from anther object 
persistence system. 



5 



In Fig.1, the synchronization executor 104a is shown as a part of the 
object persistence system 100 and the synchronization executor 104b is 
shown as a part of the object persistence system - ! 01. However, the 
synchronization executor 104a or 104b may be separately provided from the 
5 corresponding object persistence system. 

Fig. 2 shows an example of the components of the object persistence 
system 100. The object persistence system 100 includes the in-memory 
object cache 103a, a transaction manager 202a and the synchronization 
executor 104a. 

10 The transaction manager 202a is a runtime component to manage 

transactions. A transaction is a set of database operations that can either be 
committed (accepted) or rolled back (undone). Objects in the database 110 
may be changed through the transaction using the object persistence system 
100 and a database access system 210. The database access system 210 is 

15 a programming interface that enables the object persistence system 100 to 
access the database server 1 1 1 having the database 110. The transaction 
manager 202a handles updates of the database 110. Unsuccessful 
transactions can be discarded, leaving the database in its original state. 
The transaction manager 202a includes a transaction cache 203a, a 

20 computing unit 204a and a persistence executor 205a. The transaction cache 
203a is a temporary cache for storing a set of changes of a set of objects. The 
computing unit 204a is a component for computing object change sets. The 
object change sets represent information of changes of the objects, such as 
the objects in the database 1 10. The persistence executor 205a merges the 

25 object change sets into the in-memory object cache 103a. 

On a commit of the transaction, the computing unit 204a computes the 
object change sets based on the set of changes in the transaction cache 
203a. The object change sets are translated into a database language and 
sent to the database access system 210. New objects are inserted, or 

30 changed objects are updated in the database 110. 

In Fig. 2, the synchronization executor 104a is shown separately from 
the transaction manager 202a. However, the synchronization executor 1 04a 
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may be combined with or made as component of the transaction manager 
202a. 

The object persistence system 101 includes a transaction manager 
202b as shown below. The transaction manager 202b may be a similar to the 
5 transaction manager 202a. 

Fig. 3 shows a flowchart showing a modification process of the local 
and remote object persistence systems . The object persistence system 100 
is called a local object persistence system 100 and the object persistence 
system 101 is called a remote object persistence system 101. 

10 In step 301 , a modification request for modifying objects is sent to the 

local object persistence system 100. For example, an application may send 
the modification request to the object persistence system 100. The 
transaction manager 202a stores the set of changes to the objects in the 
transaction cache 203a during the transaction (step 302). When the 

15 transaction is committed (step 303), the computing unit 204a of the local 

object persistence system 100 computes the object change sets (step 304). In 
step 305, the object change sets are translated into a database language, 
such as Structured Query Language (SQL), and sent to the local database 
access system 210 to update the database 110. 

20 If no database error occurs when updating the objects of the database 

(step 306), object change sets are committed to the local in-memory object 
cache 103a by the persistence executor 205a (step 307). 

In order to synchronize the remote in-memory object cache, the 
synchronization executor 104a received the object change sets from the 

25 transaction manager 202a, The object change sets are distributed to one or 
more remote object persistence systems (step 308). The one or more remote 
persistence systems receive the object change sets and merge the object 
changes sets into their in-memory object caches (step 309). 

In this case, the remote object persistence system 101 receives the 

30 object change sets from the local object persistence system 100 and the 
persistence executor included in the remote object persistence system 101 
merges the object change sets into the in-memory object cache 103b. 
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If an error occurs when updating the database (step 306), an 
instruction for exception is returned to the local object persistence system 
(step 310). In this case, the local object persistence system 100 does not 
commit the modification of the local in-memory object cache 103a. Therefore, 
5 the local in-memory object cache 103a keeps its original state. Also, the 
object change sets will not be distributed to one or more remote object 
persistence systems, such as the remote object persistence system 101. 

Referring back to Fig. 2, the computing unit 104a computes the object 
change sets for objects that changed. Preferably, the object change sets may 

10 include a minimal set of information regarding changes to the objects. The 
advantage of distributing a minimal set of information regarding changes is 
that less data will be required to be sent across the communication link from 
the local object persistence system to the remote object persistence system. 
In this embodiment, the computing unit 104a outputs the minimal object 

15 change sets as the object change sets. 

Each object change set includes one or more changes to the attribute 
and/or data of the changed object. Each object change set further includes 
the unique identifier (referred to as a primary key value) to uniquely identify 
the changed object There are two kinds of the object classes, first object 

20 classes and aggregate object classes. The first object classes have their own 
primary keys. Thus, each of the objects in the first object classes can be 
queried with its own primary key value. The aggregate object classes do not 
have their own primary keys. Thus, each of the objects in the aggregate 
object classes is a dependent (aggregated) part of its parent object. 

25 Preferably, each object change set does not include any information as 

to attributes or data that did not change. 

Some objects which reference to one or more objects are called source 
objects. The objects referenced by the source objects are called target 
objects. A source object and a target object may have a relationship. The 

30 relationships include a one-to-one relationship, a one-to-many relationship, 
and a many-to-many relationship. 
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For example, an object change set includes one or more of (1) the 
changed value of a direct attribute of the source object, (2) the primary key 
value of the source object, (3) the primary key value of the target object of 
changed one-to-one relationships, and (4) the primary key values of the target 
5 objects added and removed from one-to-many/many-to-many relationships. 
A direct attribute is an attribute that is a simple data-type such as a 
number, string or data. The direct attribute does not include a relationship. 
When the source object is updated, the object change set may include the 
changed value of the direct attribute and the primary key value of the source 
10 object. 

For a one-to-one relationship, where one object in one object class 
refers to a single object in a different object class, a reference may be 
changed from one target object to another target object. Thus, when the 
reference is changed in the one-to-one relationship, the new primary key 
15 value of the target object is included in the object change set of the source 
object. 

For a one-to-many relationship, where one object in one object class 
refers to one or more objects in one or more object classes, the target objects 
may be added or removed. Thus, when the object is added in the one-to- 

20 many relationship, the new primary value of the target object is included in the 
object change set of the source object. 

For a many-to-many relationship, where a collection of objects in object 
classes refers to multiple objects in one or more object classes, the target 
objects may be added or removed. Thus, when the object is added in the 

25 many-to-many relationship, the new primary value of the target object is 
included in the object change set of the source object. 

Consider two object classes, "Employee" and "Address". "Employee" 
and "Address" have a one-to-one relationship. "Employee" has attributes 
"employee ID" (primary key) and "address". "Address" has attributes "code", 

30 "street". The value of "address" references an Address object. When a new 
Employee object for a new employee E1 and the new Address object for E1 is 
inserted in a database, an object change set of the new employee E1 and an 
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object change set of the new address A1 are prepared. The object change set 
of the new employee E1 includes a primary key value ("123"), the value of 
"employee ID" ("1234"), and the value of "address"( a primary key value of the 
target object ="456") as shown below. The object change set of the new 
5 address A1 includes a primary key value ("456"), the value of "code" ("456") 
and the value of "street" ("elgin") as shown below. 

(E1 change set 
PK(123) 
10 (employee ID=123) 

(address=PK(456))) 
(A1 change set 
PK(456) 
(code=456) 
15 (street="elgin")) 

Consider two object classes "Employee" and "Tel". "Employee" and 
"Tel" have a one-to-many relationship. "Employee" has attributes "employee 
ID" (primary key) and "telephones". TEL" has attributes "telephone no". 

20 "Employee" object for Employee E1 has two Telephone numbers. When a 
new TEL object T1 for the existing Employee E1 is added and the TEL object 
T2 of the Employees E1 is removed in a database, an object change set of 
the employee E1 is prepared. The object change set of the employee E1 
includes a primary key value ("123"), a primary key value of the added target 

25 object ("T1") and a primary key value of the removed target object ("T2") as 
shown below. 

(E1 change set 
PK(123) 

30 (telephones-added(PK(T1)-removed(PK(T2)))) 
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Fig.4 shows an example of the synchronization executor 104a and 
104b. The synchronization executor 104a includes a remote connector 402a, 
a synchronization manager 403a and a remote session dispatcher 404a. The 
synchronization manager 403a manages the remote connector 402a and the 
5 remote session dispatcher 404a. The synchronization executor 104b includes 
a remote connector 402b, a synchronization manager 403b and a remote 
session dispatcher 404b. The synchronization manager 403b manages the 
remote connector 402b and the remote session dispatcher 404b. 

The remote connector 402b, the synchronization manager 403b and 
10 the remote session dispatcher 404b are similar to the remote connector 402a, 
the synchronization manager 403a and the remote session dispatcher 404a, 
respectively. 

The remote connector 402a couples to the remote session dispatcher 
404b via a communication link 420. The remote connector 402b couples to 

15 the remote session dispatcher 404a via the communication link 420. 

For example, consider that the object persistence system 100 is the 
local object persistence system and the object persistence system 101 is the 
remote object persistence system. 

In the local object persistence system 100, the persistence executor 

20 205a (Fig. 2) merges the object change sets into the local in-memory object 
cache 103a. The transaction manager 202a sends the object change sets to 
the synchronization executor 104a. The object change sets will be distributed 
through the communication link 420 from the remote session dispatcher 404a 
of the local object persistence system 100 to the remote connector 402b of 

25 the remote object persistence system 101. 

In the remote object persistence system 401, the synchronization 
manager 403b may send the received object change sets to the transaction 
manager 202b. The persistence executor of the remote object persistence 
system 101 may merge them into the remote in-memory object cache 103b. 

30 Fig. 5 shows an example of the persistence executor 205a. The 

persistence executor 205a includes a searching unit 501, a merging unit 502 
and a discarding unit 503. 
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The searching unit 501 looks up an object for each object change set 
by its primary key value. On the receipt of an object change set, the searching 
process of the searching unit 501 is executed. If the object is in the in-memory 
cache 103a, the merging unit 502 takes the object change set and applies the 
5 changes to the object in the in-memory object cache 103a. Otherwise, the 
discarding unit 503 discards the object change set. 

For the direct attributes, the target object's attribute value is set to the 
new value. For one-to-one relationships, the new primary key value in the 
object change set of the source object is used to find the target object from 
10 the in-memory object cache 103a and set the attribute to the new object. If the 
target object is not found in the in-memory object cache 103a, the target 
object is found/queried from the database and cached in the in-memory object 
cache. 

For one-to-many and many-to-many relationships, the one-to- 

15 many/many-to-many change record contains the added and removed objects. 
For each added object, the primary key value in the object change set of the 
source object is used to find the target object from the in-memory object 
cache and add the found object to the collection. For removed objects, the 
primary key value in the object change set of the source object is used to 

20 iterate over the target's collection and remove the object with matching 
primary key value. 

This results in the object having the same state as the object to which 
the changes were originally made. This reduces the probability of stale data 
and potential data corruption. Therefore, the performance benefit of caching is 

25 achieved. Read operations using the in-memory object cache will be able to 
obtain a cache hit and avoid database access. This process, could add 
additional complexity to write operations, however, performance reduction 
related to such complexity is minimized by only distributing the minimal set of 
changes to the objects. 

30 In order for a group of object persistence systems (residing on 

database clients or application servers as shown below ) to synchronize their 
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in-memory object caches with each other, they establish a communication link 
with each other. For example, a publish/subscribe protocol may be used. 

When each object persistence system comes on-line, each object 
persistence system sends out its unique session identifier to the group of 
5 object persistence systems (i.e. online object persistence systems). Each 
object persistence system in the group that is on-line will receive the session 
identifier and then request synchronization with the object persistence system 
that sent the session identifier. 

Figs.6-8 are pictorial diagrams illustrating a scenario showing the 
10 establishment of such a communication link. In Figs 6-8, each object 

persistence system 601, 701, 801 is similar to the object persistence system 
100. 

Referring to Fig. 6, there are an object persistence system 601 and a 
client 602. The client 602 may manage the database through the object 
1 5 persistence system 601 . 

Referring to Fig. 7, when an object persistence system 701 comes on- 
line, the object persistence system 701 sends out its unique session identifier 
to the object persistence system 601 (step 710). The object persistence 
system 601 receives the session identifier and then requests synchronization 
20 with the object persistence system 701 (step 71 1 ). 

Referring to Fig. 8, the object persistence systems 601 and 701 
communicate with each other (steps 810, 81 1). When an object persistence 
system 801 comes on-line, the object persistence system 801 sends out the 
unique session identifier to the object persistence systems 601, 701, 
25 respectively (steps 81 2, 81 3). The object persistence systems 601 ,701 

receive the session identifier and then request synchronization with the object 
persistence system 801, respectively (steps 814, 815). 

Likewise, when the object persistence system receives one or more 
requests from one or more object persistence systems (referred to as a 
30 requestor), the object persistence system that receives the request will in turn 
send a request back to the requestor. Through bi-directional requests, each 
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object persistence system will know about all of the other object persistence 
systems in the group. 

In Fig. 7, the object persistence system 701 sends out its unique 
identifier and the object persistence system 601 requests synchronization with 

5 the object persistence system 701 .However, the object persistence system 
601 may send out its unique identifier and the object persistence system 701 
may request synchronization with the object persistence system 601 . 

In Fig. 8, the object persistence system 801 sends out their unique 
identifier and the object persistence systems 601,701 request synchronization 

10 with the object persistence system 801 . However, the object persistence 
systems 601, 701 may send out their unique identifiers and the object 
persistence system 801 may request synchronization with the object 
persistence systems 601, 701. 

Each object persistence system 601,701,801 may have a synchronous 

15 mode and an asynchronous mode. In the synchronous mode, execution 

control of each local object persistence system is blocked and is not returned 
to the client of the object persistence system until changes have been 
processed by each remote object persistence system. In the asynchronous 
mode, the local object persistence system returns to the client and the 

20 changes are sent to the remote object persistence system in the background. 
Execution control means the active thread/process in a multiple 
threaded system where the object persistence systems 601,701, and 801 are 
multiple thread systems. When execution control is blocked in a system, the 
other servers are synchronized either in a background thread or in the client's 

25 thread. 

Referring to Fig. 8, consider that the object persistence systems 601, 
701 and 801 have clients 602, 702 and 802, respectively. In the synchronous 
mode, execution control of the object persistence systems 601, 701 and 801 is 
blocked to the clients 602, 702 and 802 until the changes have been 
30 processed by each object persistence system. In the asynchronous mode, 
execution control of the object persistence systems 601, 701 and 801 is 
returned to the clients 602,702 and 802 and the changes of each object 
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persistence system are sent to the remote object persistence systems in the 
group. This allows the object change sets of the local object persistence 
system to be distributed to the remote object persistence systems 
asynchronously to the client of the local object persistence system. Therefore, 
5 write performance is not affected by object cache synchronization. 

Fig. 9 shows an example of application servers to which the object 
persistence system 100 is applied. In Fig.9, the object persistence system 100 
is implemented using a 3-tier architecture. The application servers 901 and 
902 can couple to one or more databases. In Fig.9, one database 110 and 
10 one database server 1 1 1 are represented for simplicity. One of ordinary skill 
in the art can readily apply the concepts described herein to multiple 
databases. Application servers 901 and 902 provide services to clients 905 
and 906 in response to clients' requests, such as read requests and 
modification requests. 
15 The application server 901 includes an object persistence system 

100a, a database access system 210a and an application 903. The 
application 903 may access the object persistence system 100a . 

The application server 902 includes an object persistence system 
100b, a database access system 210b and an application 904. The 
20 application 904 may access the object persistence system 100b. 

Each object persistence system 100a, 100b may be similar to the 
object persistence system 100. 

The database access system 210a is a programming interface that 
enables the object persistence system 100a to access the database server 
25 1 1 1 . The database access system 21 0b is a programming interface that 
enables the object persistence system 100b to access the database server 
111. Each database access system 210a, 210b may be similar to the 
database access system 210. 

The object persistence systems 100a and 100b are connected through 
30 a communication mechanism/system (not shown), such as Remote Method 
Invocation (RMI), Common Object Request Broker Architecture (CORBA), 
SessionBeans, and multicast sockets, which enable the object persistence 
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systems 100 to establish a communication link between each other, though 
any other communication mechanism may be used such that communication 
may be effected between object persistence systems. 

For example, the object change sets of the local application server 901 
are distributed through a communication mechanism or network protocol to 
the application server 902 that maintains an in-memory object cache. Each 
object persistence system 100a, 100b integrates and supports persistence in 
the application servers. The object persistence systems 100a and100b allow 
applications 903 and 904, respectively, to transparently store and retrieve 
objects using the databases. 

Fig. 10 shows another example of database clients to which the object 
persistence system 100 is applied. In Fig. 10, the object persistence system 
100 is implemented using a 2-tier architecture. Clients 1001 and 1002 can 
couple to one or more databases. In Fig. 10, one database 110 and one 
database server 1 1 1 are represented for simplicity. One of ordinary skill in the 
art would readily apply the concepts described herein to multiple databases. 
Clients 1001 and 1002 generate requests and transmit them to the database 
server 1 1 1 . The database client 1001 includes the object persistence system 
100c, a database access system 210c and an application 1003. The database 
client 1002 includes the object persistence system 100d, a database access 
system 21 Od and an application 1004. 

Each object persistence system 100c, 100d may be similar to the 
object persistence system 100. 

The database access system 210c is a programming interface that 
enables the object persistence system 100c to access the database server 
111. The database access system 21 Od is a programming interface that 
enables the object persistence system 100d to access the database server 
111. Each database access system 210c,210d may be similar to the database 
access system 210. 

The applications 1003 and 1004may access the object persistence 
systemslOOc and 100d, respectively. 
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The object persistence systems 1 00s and 1 0Od are connected 
through a communication mechanism/system (not shown), which enables the 
object persistence systems 100c and 100d to establish a communication link 
between each other. 

5 For example, the object change sets of the local database client 1 001 

are distributed through a communication mechanism or network protocol to 
the database client 1002 that maintains in-memory object cache(s). 

Each object persistence system 100c, 100d integrates and supports 
persistence in database clients. The object persistence systems 100c and 

10 1 0Od allow applications 403 and 404, respectively, to transparently store and 
retrieve objects using the databases. According to the present invention, the 
object persistence system can manage the set of objects dynamically. 

Further, connections between the object persistence systems can be 
managed when one or more on-line object persistence systems shutdown and 

15 startup. 

Referring back to Fig.1 , consider that the object persistence systems 
100-102 come on-line and the object persistence system 101 shuts down. 
Then, object persistence system 101 will be removed from the group. 
However, when the object persistence system 101 starts up, the object 

20 persistence system 101 will be added to the group through the same bi- 
directional mechanism as described above. 

The synchronization executor of the present invention may be 
implemented by any hardware, software or a combination of hardware and 
software having the above described functions. The software code, either in 

25 its entirety or a part thereof, may be stored in a computer readable memory. 
Further, a computer data signal representing the software code which may be 
embedded in a carrier wave may be transmitted via a communication network. 
Such a computer readable memory and a computer data signal are also 
within the scope of the present invention, as well as the hardware, software 

30 and the combination thereof .While particular embodiments of the present 
invention have been shown and described, changes and modifications may 
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be made to such embodiments without departing from the true scope 
invention. 
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